HomeTabs.tsx 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. "use client";
  2. import { ConfigType } from "@/api/config";
  3. import { GroupType } from "@/api/home";
  4. import Box from "@/components/Box";
  5. import { useRouter } from "@/i18n/routing";
  6. import { Toast } from "antd-mobile";
  7. import clsx from "clsx";
  8. import { useTranslations } from "next-intl";
  9. import { FC, useState } from "react";
  10. import { Swiper, SwiperSlide } from "swiper/react";
  11. import HomeGames from "./HomeGames";
  12. const buttonGroup = [
  13. {
  14. icon: "qianbao3",
  15. category_name: "sixth",
  16. isHot: false,
  17. url: "/freeGames",
  18. locale: true,
  19. lock: false,
  20. },
  21. {
  22. icon: "qianbao3",
  23. category_name: "seventh",
  24. isHot: false,
  25. url: "/replayGames",
  26. locale: true,
  27. lock: false,
  28. },
  29. {
  30. icon: "liwulipinjiangpin",
  31. category_name: "first",
  32. isHot: true,
  33. url: "/promo",
  34. locale: true,
  35. lock: false,
  36. },
  37. // {
  38. // icon: "pro-youxi1",
  39. // category_name: "second",
  40. // isHot: false,
  41. // url: "/gameList/110",
  42. // locale: true,
  43. // lock: true,
  44. // },
  45. {
  46. icon: "huodongyule",
  47. category_name: "third",
  48. isHot: false,
  49. url: "/sports",
  50. locale: true,
  51. lock: false,
  52. },
  53. {
  54. icon: "shipin",
  55. category_name: "fourth",
  56. isHot: false,
  57. url: "/gameList/112",
  58. locale: true,
  59. lock: true,
  60. },
  61. {
  62. icon: "yingyong",
  63. category_name: "Fifth",
  64. isHot: false,
  65. url: "/gameList/110",
  66. locale: true,
  67. lock: true,
  68. },
  69. ] as const;
  70. type TabItemType = (typeof buttonGroup)[number] & GroupType;
  71. const TabItem = ({
  72. item,
  73. active,
  74. onClick,
  75. }: {
  76. item: TabItemType;
  77. active?: boolean;
  78. onClick?: (item: TabItemType) => void;
  79. }) => {
  80. const t = useTranslations("ButtonGroup");
  81. const router = useRouter();
  82. const handler = (item: TabItemType) => {
  83. if (!item.locale) {
  84. onClick && onClick(item);
  85. return;
  86. }
  87. if (item.lock) {
  88. Toast.show("It is under development.");
  89. } else {
  90. router.push(item.url);
  91. }
  92. };
  93. const cls = clsx("pro-iconfont text-[0.14rem]", `pro-${item.icon}`);
  94. const cls2 = clsx("iconfont text-[0.145rem]", `icon-${item.icon}`);
  95. const rootCls = clsx(
  96. "relative mr-[0.06rem] flex h-[0.3rem] bg-[#3a3a3a] flex-1 cursor-pointer items-center" +
  97. " rounded-[0.05rem] px-[0.08rem] py-[0.03rem] text-[0.12rem] text-[#fff]",
  98. { "bg-primary-color": active }
  99. );
  100. return (
  101. <div className={rootCls} onClick={() => handler(item)}>
  102. <span className={item.icon === 'qianbao3' ? cls2 : cls}></span>
  103. <span className={"ml-[0.03rem] truncate"}>
  104. {item.locale ? t(item.category_name) : item.category_name}
  105. </span>
  106. {item.isHot && (
  107. <img
  108. className={"absolute -top-[0.12rem] right-0 h-[0.21rem] w-[0.21rem]"}
  109. src="data:image/png;base64,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"
  110. alt=""
  111. />
  112. )}
  113. </div>
  114. );
  115. };
  116. interface Props {
  117. tabs: GroupType[];
  118. config: ConfigType;
  119. }
  120. const Tabs: FC<Props> = (props) => {
  121. const { tabs, config = { show_free_game: 2, show_again_game: 2 } } = props;
  122. const newButtonGroup = buttonGroup.filter((item: any) => {
  123. if (item.url === "/freeGames" && config.show_free_game !== 1) {
  124. return false;
  125. }
  126. if (item.url === "/replayGames" && config.show_again_game !== 1) {
  127. return false;
  128. }
  129. return true;
  130. });
  131. const tabData = [...tabs, ...newButtonGroup];
  132. const [active, setActive] = useState<number>(0);
  133. const router = useRouter();
  134. const selectHandler = (item: TabItemType, index: number) => {
  135. if (item.bet_type === 2 || item.bet_type === 3) {
  136. router.push(
  137. `/gameList/?gameListFlag=${item.category[0].jump_id}&type=1&bet_type=${item.bet_type}`
  138. );
  139. return;
  140. }
  141. setActive(index);
  142. };
  143. const groupGames = tabs[active]?.category;
  144. return (
  145. <>
  146. <Box pt={false}>
  147. <Swiper slidesPerView={"auto"} centeredSlidesBounds>
  148. {tabData?.map((group, index) => (
  149. <SwiperSlide key={index} className={"max-w-fit pt-[0.1389rem]"}>
  150. <TabItem
  151. item={group as TabItemType}
  152. active={index === active}
  153. onClick={(event) => selectHandler(event, index)}
  154. ></TabItem>
  155. </SwiperSlide>
  156. ))}
  157. </Swiper>
  158. </Box>
  159. <HomeGames groupGames={groupGames} />
  160. </>
  161. );
  162. };
  163. export default Tabs;